

# **Digilent Intellectual Property Specification**

Revision 1.0

## **DIPS-01: DIGILENT VIDEO MEMORY ACCESS SPECIFICATION**

This specification defines the specifications for Digilent Video Memory Access IP Core.

# **Revision Log**

| Revision # | ROIN | Change          | Author        | Date      |
|------------|------|-----------------|---------------|-----------|
| 1.0        | All  | Initial Release | WANG, Tinghui | 20FEB2011 |

#### **DIPS-01-001 Module Overview**

- DVMA (Digilent Video Memory Access) IP Core, as shown in Fig. 1, reads 2D video data from VFBC (Video Frame Buffer Interface) interface of MPMC (Multi-Port Memory Controller) and transfers the video data into standard XSVI (Xilinx Streaming Video Interface).
- Features:
  - 32-bit PLB slave interface
  - Configurable 8, 16, 32-bit VFBC Interface.
  - Configurable XSVI video data bit width.
  - Configurable output video timing parameters.



Fig. 1 Block Diagram of VDMA v1.0

# DIPS-01-002 I/O Signals

DVMA I/O Signals are shown in Table 1.

Table 1 DVMA IP Core I/O Signals Description

| NO                             |                                                                                                                   | Core I/O Signal INTERFACE | I/O     | INIT ST. | DESCRIPTION                                       |  |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------|---------------------------|---------|----------|---------------------------------------------------|--|
| NO.                            | SIGNAL NAME                                                                                                       | System Signals            | 1/0     | INII SI. | DESCRIPTION                                       |  |
| D1                             |                                                                                                                   |                           | Т       |          | PLB clock                                         |  |
| P1<br>P2                       | SPLB_Clk<br>SPLB_Rst                                                                                              | System<br>System          | I       | -        | PLB clock PLB reset, active high                  |  |
| ΓZ                             |                                                                                                                   |                           |         | -        | FLB leset, active high                            |  |
| D2                             | PLB Interface Signals           P3         PLB ABus[0:31]         PLB         I         -         PLB address bus |                           |         |          |                                                   |  |
| P3<br>P4                       | PLB_ABus[0:31] PLB_PAValid                                                                                        | PLB                       | I       | -        | PLB address bus PLB primary address valid         |  |
| P5                             | PLB_masterID[0 : C_SPLB_MID_WIDTH - 1]                                                                            | PLB                       | I       |          | PLB current master identifier                     |  |
| P6                             | PLB_masteriD[0 : C_SPLB_MID_wID1H - 1] PLB_RNW                                                                    | PLB                       | I       | -        | PLB current master identifier  PLB read not write |  |
| P7                             | PLB_BE[0 : (C_SPLB_DWIDTH/8) - 1]                                                                                 | PLB                       | I       | -        | PLB byte enables                                  |  |
| P8                             | PLB_size[0 : 3]                                                                                                   | PLB                       | I       | -        | PLB size of requested transfer                    |  |
| P9                             | PLB_type[0:2]                                                                                                     | PLB                       | I       | -        | PLB size of requested transfer  PLB transfer type |  |
| P10                            | PLB_wrDBus[0 : C_SPLB_DWIDTH - 1]                                                                                 | PLB                       | I       | -        | PLB write data bus                                |  |
| 110                            |                                                                                                                   | PLB Interface Sig         | _       | _        | I LB write data bus                               |  |
| P11                            | PLB_UABus[0:31]                                                                                                   | PLB                       | I       | _        | PLB upper address bits                            |  |
| P12                            | PLB_SAValid                                                                                                       | PLB                       | I       |          | PLB secondary address valid                       |  |
| F1Z                            | FLD_SA valid                                                                                                      | FLD                       | 1       | -        | PLB secondary to primary read                     |  |
| P13                            | PLB_rdPrim                                                                                                        | PLB                       | I       | -        | request indicator                                 |  |
|                                |                                                                                                                   |                           |         |          | PLB secondary to primary write                    |  |
| P14                            | PLB_wrPrim                                                                                                        | PLB                       | I       | -        | request indicator                                 |  |
| P15                            | PLB_abort                                                                                                         | PLB                       | I       | _        | PLB abort bus request                             |  |
| P16                            | PLB_busLock                                                                                                       | PLB                       | I       |          | PLB bus lock                                      |  |
| P17                            | PLB_MSize[0:1]                                                                                                    | PLB                       | I       | _        | PLB data bus width indicator                      |  |
| P18                            | PLB_lockErr                                                                                                       | PLB                       | I       |          | PLB lock error                                    |  |
| P19                            | PLB_wrBurst                                                                                                       | PLB                       | I       | _        | PLB burst write transfer                          |  |
| P20                            | PLB_rdBurst                                                                                                       | PLB                       | I       | _        | PLB burst read transfer                           |  |
| P21                            | PLB_wrPendReq                                                                                                     | PLB                       | I       | _        | PLB pending bus write request                     |  |
| P22                            | PLB_rdPendReq                                                                                                     | PLB                       | I       | _        | PLB pending bus read request                      |  |
|                                | 1 LD_tar charceq                                                                                                  |                           | 1       | _        | PLB pending write request                         |  |
| P23                            | PLB_wrPendPri[0 : 1]                                                                                              | PLB                       | I       | -        | priority                                          |  |
| P24                            | PLB_rdPendPri[0 : 1]                                                                                              | PLB                       | I       | -        | PLB pending read request priority                 |  |
| P25                            | PLB_reqPri[0:1]                                                                                                   | PLB                       | I       | _        | PLB current request priority                      |  |
| P26                            | PLB_TAttribute[0:15]                                                                                              | PLB                       | Ī       | _        | PLB transfer attribute                            |  |
| 120                            |                                                                                                                   | ave Interface Sign        | als     |          | TBB transfer and out                              |  |
| P27                            | Sl_addrAck                                                                                                        | PLB                       | 0       | 0        | Slave address acknowledge                         |  |
| P28                            | Sl_SSize[0 : 1]                                                                                                   | PLB                       | 0       | 0        | Slave data bus size                               |  |
| P29                            | Sl_wait                                                                                                           | PLB                       | 0       | 0        | Slave wait                                        |  |
| P30                            | Sl_rearbitrate                                                                                                    | PLB                       | 0       | 0        | Slave bus rearbitrate                             |  |
| P31                            | Sl wrDAck                                                                                                         | PLB                       | 0       | 0        | Slave write data acknowledge                      |  |
| P32                            | Sl_wrComp                                                                                                         | PLB                       | 0       | 0        | Slave write transfer complete                     |  |
| P33                            | Sl_rdDBus[0 : C_SPLB_DWIDTH - 1]                                                                                  | PLB                       | 0       | 0        | Slave read data bus                               |  |
| P34                            | Sl_rdDAck                                                                                                         | PLB                       | 0       | 0        | Slave read data acknowledge                       |  |
| P35                            | Sl_rdComp                                                                                                         | PLB                       | 0       | 0        | Slave read transfer complete                      |  |
| P36                            | Sl_MBusy[0 : C_SPLB_NUM_MASTERS - 1]                                                                              | PLB                       | 0       | 0        | Slave busy                                        |  |
| P37                            | Sl_MWrErr[0 : C_SPLB_NUM_MASTERS - 1]                                                                             | PLB                       | 0       | 0        | Slave write error                                 |  |
| P38                            | Sl_MRdErr[0 : C_SPLB_NUM_MASTERS - 1]                                                                             | PLB                       | 0       | 0        | Slave read error                                  |  |
|                                | ,                                                                                                                 | B Slave Interface         | Signals |          |                                                   |  |
| Das                            |                                                                                                                   |                           | Γ       |          | Slave terminate write burst                       |  |
| P39                            | Sl_wrBTerm                                                                                                        | PLB                       | О       | 0        | transfer                                          |  |
| P40                            | Sl_rdWdAddr[0:3]                                                                                                  | PLB                       | О       | 0        | Slave read word address                           |  |
| P41                            | Sl_rdBTerm                                                                                                        | PLB                       | 0       | 0        | Slave terminate read burst transfer               |  |
| P42                            | Sl_MIRQ[0 : C_SPLB_NUM_MASTERS - 1]                                                                               | PLB                       | 0       | 0        | Master interrupt request                          |  |
| 1 72                           | 7-                                                                                                                | OVMA Signals              |         | ı v      | master merrupt request                            |  |
| P43                            | PIXCLK_I                                                                                                          | DVMA                      | I       |          | Video Pixel Clock                                 |  |
| P43<br>P44                     | PLL_LOCKED_I                                                                                                      | DVMA                      | I       | -        | Pixel Clock PLL Locked                            |  |
| P44<br>P45                     | DEBUG_O                                                                                                           | DVMA                      | 0       | 0        | Debug Signal Output                               |  |
| 143                            |                                                                                                                   |                           | _       | U        | Dooug Signal Output                               |  |
| VFBC Command Interface Signals |                                                                                                                   |                           |         |          |                                                   |  |

| NO. | SIGNAL NAME                                                           | INTERFACE          | I/O  | INIT ST. | DESCRIPTION                 |
|-----|-----------------------------------------------------------------------|--------------------|------|----------|-----------------------------|
|     | VFBC_CMD_CLK                                                          | VFBC               | О    | 0        | VFBC Command Clock          |
|     | VFBC_CMD_RESET                                                        | VFBC               | 0    | 0        | VFBC Command Reset          |
|     | VFBC_CMD_DATA[31:0]                                                   | VFBC               | О    | 0        | VFBC Command Data           |
|     | VFBC_CMD_WRITE                                                        | VFBC               | 0    | 0        | VFBC Command Write Enable   |
|     | VFBC_CMD_END                                                          | VFBC               | 0    | 0        | VFBC Command End            |
|     | VFBC_CMD_FULL                                                         | VFBC               | I    | -        | VFBC Command Full           |
|     | VFBC_CMD_ALMOST_FULL                                                  | VFBC               | I    | -        | VFBC Command Almost Full    |
|     | VFBC_CMD_IDLE                                                         | VFBC               | I    | -        | VFBC Command Idle           |
|     | VFBC R                                                                | ead Interface Sign | nals |          |                             |
|     | VFBC_RD_CLK                                                           | VFBC               | 0    | 0        | VFBC Read Data Clock        |
|     | VFBC_RD_RESET                                                         | VFBC               | 0    | 0        | VFBC Read Data Reset        |
|     | VFBC_RD_READ                                                          | VFBC               | О    | 0        | VFBC Read Data Read Enable  |
|     | VFBC_RD_END_BURST                                                     | VFBC               | 0    | 0        | VFBC Read Data End Burst    |
|     | VFBC_RD_FLUSH                                                         | VFBC               | 0    | 0        | VFBC Read Data Flush        |
|     | VFBC_RD_DATA [C_VFBC_RDWD_DATA_WIDTH-1:0]                             | VFBC               | I    | -        | VFBC Read Data              |
|     | VFBC_RD_EMPTY                                                         | VFBC               | I    | -        | VFBC Read Data Empty        |
|     | VFBC_RD_ALMOST_EMPTY                                                  | VFBC               | I    | -        | VFBC Read Data Almost Empty |
|     |                                                                       | XSVI Signals       |      |          |                             |
|     | XSVI_PIXCLK                                                           | XSVI               | 0    | 0        | XSVI Video Clock            |
|     | XSVI_HSYNC                                                            | XSVI               | 0    | 0        | XSVI Horizontal Synchronize |
|     | XSVI_VSYNC                                                            | XSVI               | О    | 0        | XSVI Vertical Synchronize   |
|     | XSVI_ACTIVE_VIDEO                                                     | XSVI               | О    | 0        | XSVI Video Active           |
|     | XSVI_VIDEO_DATA [C_NUM_DATA_CHANNELS* C_DATA_WIDTH/(C_DDR_OUT+1)-1:0] | XSVI               | О    | 0        | XSVI Video Data             |

# **DIPS-01-003 Software Register Mapping**

DVMA core contains the registers listed in Table 3.

Table 2 Register Name and Descriptions of DVMA

| REGISTER NAME                          | ADDRESS                  | ACCESS     |
|----------------------------------------|--------------------------|------------|
| Control Register (CR)                  | C_DVMA_BASEADDR + 0x00   | Read/Write |
| Frame Width Register (FWR)             | C_DVMA_BASEADDR + 0x04   | Read/Write |
| Frame Height Register (FHR)            | $C_DVMA_BASEADDR + 0x08$ | Read/Write |
| Frame Base Address Register (FBAR)     | $C_DVMA_BASEADDR + 0x0c$ | Read/Write |
| Frame Line Stride Register (FLSR)      | $C_DVMA_BASEADDR + 0x10$ | Read/Write |
| Horizontal Synchronize Register (HSR)  | C_DVMA_BASEADDR + 0x14   | Read/Write |
| Horizontal Front Porch Register (HFPR) | C_DVMA_BASEADDR + 0x18   | Read/Write |
| Horizontal Back Porch Register (HBPR)  | C_DVMA_BASEADDR + 0x1c   | Read/Write |
| Horizontal Total Register (HTR)        | C_DVMA_BASEADDR + 0x20   | Read/Write |
| Vertical Synchronize Register (VSR)    | C_DVMA_BASEADDR + 0x24   | Read/Write |
| Vertical Front Porch Register (VFPR)   | C_DVMA_BASEADDR + 0x28   | Read/Write |
| Vertical Back Porch Register (VBPR)    | C_DVMA_BASEADDR + 0x2c   | Read/Write |
| Vertical Total Register (VTR)          | C_DVMA_BASEADDR + 0x30   | Read/Write |

## Control Register (CR)

Bit 31: DVMA Enable ("1" – enable; "0" – disable)

Bit 0-30: Reserved





Fig. 2 VFBC 2D Transfer Parameters

#### Frame Width Register (FWR)

Width of output frame, counted in pixels (as shown in Fig 2)

#### Frame Height Register (FHR)

Height of output frame, counted in lines

#### Frame Base Address Register (FBAR)

Base address of output frame in physical memory (only last 31 bits are valid) (as shown in Fig 2)

#### Frame Line Stride Register (FLSR)

Number of pixels between the beginning of two adjacent lines in memory (as shown in Fig 2).

#### Horizontal Synchronize Register (HSR)

The width of horizontal synchronize signal, counted in pixels (as shown in Fig 3).

#### Horizontal Front Porch Register (HFPR)

Number of pixels between the start of Horizontal Synchronize and the end of Horizontal Front Porch (as shown in Fig 3)

### Horizontal Back Porch Register (HBPR)

Number of pixels between the start of Horizontal Synchronize Signal and the beginning of Horizontal Front Porch (as shown in Fig 3)

#### Horizontal Total Register (HTR)

Total pixels per line (as shown in Fig 3)

#### Vertical Synchronize Register (VSR)

The width of Vertical Synchronize Signal, counted in lines (as shown in Fig 3)

#### Vertical Front Porch Register (VFPR)

Number of lines between the start of Vertical Synchronize Signal and the end of Vertical Front Porch (as shown in Fig 3)

## Vertical Back Porch Register (VBPR)

Number of pixels between the positive edge of Hsync signal and the beginning of Horizontal Front Porch (as shown in Fig 3)

## Vertical Total Register (VTR)

Total lines per frame (as shown in Fig 3)



Fig. 3 Register Values for Video Synchronization